/**
 *给你链表的头节点 head ，每 k 个节点一组进行翻转，请你返回修改后的链表。
 *
 * k 是一个正整数，它的值小于或等于链表的长度。如果节点总数不是 k 的整数倍，那么请将最后剩余的节点保持原有顺序。
 *
 * 你不能只是单纯的改变节点内部的值，而是需要实际进行节点交换。
 * 递归法
 *https://leetcode.cn/problems/reverse-nodes-in-k-group/description/
 */
class ReverseKGroupDiGui {
    public ListNode reverseKGroup(ListNode head, int k) {
        if(head == null) {
            return head;
        }
        ListNode a = head;
        ListNode b = head;
        for(int i = 0;i<k;i++) {
            if(b==null) {
                return head;
            }
            b = b.next;
        }
        ListNode newHead = reverse(a,b);
        a.next = reverseKGroup(b,k);
        return newHead;
    }

    private ListNode reverse(ListNode a,ListNode b) {
        ListNode pre = null;
        ListNode cur = a;
        ListNode nex = a;
        while(cur!=b) {
            nex = cur.next;
            cur.next = pre;
            pre = cur;
            cur = nex;
        }
        return pre;
    }
}